/*
 * Copyright 2013 ZXing authors
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

namespace ZXing.QrCode.Internal
{
   /// <summary>
   /// Meta-data container for QR Code decoding. Instances of this class may be used to convey information back to the
   /// decoding caller. Callers are expected to process this.
   /// </summary>
   public sealed class QRCodeDecoderMetaData
   {
      private readonly bool mirrored;

      /// <summary>
      /// Initializes a new instance of the <see cref="QRCodeDecoderMetaData"/> class.
      /// </summary>
      /// <param name="mirrored">if set to <c>true</c> [mirrored].</param>
      public QRCodeDecoderMetaData(bool mirrored)
      {
         this.mirrored = mirrored;
      }

      /// <summary>
      /// true if the QR Code was mirrored. 
      /// </summary>
      public bool IsMirrored
      {
         get { return mirrored; }
      }

      /// <summary>
      /// Apply the result points' order correction due to mirroring.
      /// </summary>
      /// <param name="points">Array of points to apply mirror correction to.</param>
      public void applyMirroredCorrection(ResultPoint[] points)
      {
         if (!mirrored || points == null || points.Length < 3)
         {
            return;
         }
         ResultPoint bottomLeft = points[0];
         points[0] = points[2];
         points[2] = bottomLeft;
         // No need to 'fix' top-left and alignment pattern.
      }
   }
}